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BACKGROUND 



This invention relates to systems and methods for minimizing harmonic in a 
communications circuit. 

Frequency conversion is the process of changing one frequency to another. This 
may occur in instances when one signal is multiplied with a second signal to produce, a 
sum and/or difference of the signals. Frequency conversion circuits are commonly used 
in transmitters/receivers to convert an outgoing/incoming Intermediate Frequency/Radio 
Frequency (IF/RF) signal to the RF/IF signal. In case of receivers the IF signal is further 
processed by circuits following the frequency conversion circuit to develop a suitable 
signal for passing to a demodulator. The demodulator recovers the information encoded 
into the IF signal The frequency conversion circuit produces the IF signal by mixing the 
RF signal with one or more local oscillator (LO) signals using a mixer. 

Wireless receivers usually use several mixers to take the RF signal from the 
antenna and shift it to the lower IF frequency. This procedure usually will help on 
sampling the data and going to the digital domain. The frequency of the IF signal will be 
determined by the separation in frequency between the radio frequency signal and the 
local oscillator signals. The mixer receives separate input signals and combines the 
signals to produce an output signal. The mixer allows very high frequency to be down- 
converted to baseband or IF so that signals may be evaluated using analog or digital 




signal processing techniques. In another example, the mixer up-converts a low frequency 
to a high frequency. 

Potential detrimental interference can arise in the IF circuit. One form of 
detrimental interference includes harmonic interference, also referred to as "harmonic*'. 
Harmonics are generally spectral components of a signal that can interfere with proper 
operation of the wireless receiver. These digital transceiver ICs typically deploy many 
clocks in the same IC running at different frequencies. The problem becomes more 
pronounced for single chip digital RF transceivers since such single chip solution for 
wireless receivers requires combining the RF and Base Band processing. The effect of the 
harmonic of any of these clocks on the mixed signal part of the IC becomes significant. 
As an example of this problem, the third harmonic of a 1 MHz clock at the output of the 
last mixer appears as an IF signal at 3 MHz. This third harmonic of the 1 MHz clock will 
show up as a 3 MHz signal at the output of the IF mixer at 3 MHz and during the 
demodulation process this will look like a DC offset, which is undesirable. 
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SUMMARY 

In one aspect, a method minimizes nth-order harmonic associated with a square 
wave clock signal having a predetermined frequency and a duty cycle by changing the 
duty cycle of the clock to eliminate or suppress the nth-order harmonic of the clock; and 
5 generating a low-interference clock having the changed duty cycle while keeping the 
predetermined frequency. 

Implementations of the above aspect may include one or more of the following: 
Generating a low-interference clock further comprises generating an asymmetrical clock 
signal. Changing the duty cycle can change the position of the falling edge of the square 
10 wave clock relative to the position of the rising edge of the clock. Minimizing the nth- 
order harmonic changes the magnitude of the other harmonic. The resulting low- 
interference clock can be used in digital transceivers. 

In another aspect, a system for minimizing nth-order harmonic associated with a 
square wave clock signal having a predetermined frequency and a duty cycle includes 
ll 1 5 means for changing the duty cycle of the clock to eliminate or suppress the nth-order 
harmonic of the clock; and means for generating a low-interference clock having the 
changed duty cycle while keeping the predetermined frequency. 

Implementations of the above aspect may include one or more of the following. 
The means for generating a low-interference clock further includes means for generating 
20 an asymmetrical clock signal. The means for changing the duty cycle further comprises 
means for changing the position of the falling edge of the square wave clock relative to 
the position of the rising edge of the clock. The Minimizing of the nth-order harmonic 
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changes the magnitude of other harmonic. The low-interference clock can be used in a 
digital radio transceiver. 

In another aspect, a clock generator includes a clock oscillator; a down counter 
coupled to the clock oscillator; and a controller coupled to the down counter to generate a 
5 low harmonic clock with an asymmetrical duty cycle. 

Implementations of the above aspect may include one or more of the following: 
The clock oscillator generates an output at a high frequency relative to the desirable low 
frequency clock rate. The counter is a modular down counter. The controller can 
change the position of the falling edge of the clock relative to the position of the rising 
10 edge of the clock. The controller can minimize the nth-order harmonic and changes the 
magnitude of other harmonic, 
ff j Advantages of the above system and method may include one or more of the 

following. The system reduces nth-order harmonic to almost zero without requiring the 
use of higher grade components or employing additional shielding around noisy 
g 15 components (through, for example, a metal shield to enclose the noisy device). The 
system achieves higher performance in a cost-effective manner. 

The above system provides a method for suppressing adverse harmonic of the 
signal. Changing the duty cycle of the digital clock reduces or eliminates various specific 
harmonics. Additionally, one or more design parameters can be modified to reduce or 
20 eliminate unwanted harmonics. The system reduces a specific signal interference 

problem on a chip and minimizes the effect of the harmonics of the clocks on a chip on 
other parts of the chip. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 shows an exemplary square wave signal. 

FIG. 2 shows an exemplary clock generator in accordance with the present 
invention. 

5 FIG. 3 shows an exemplary process for generating clock signals with minimal 

interference. 

FIG. 4 shows power spectrum charts for a IKHz clock (symmetrical and 
asymmetrical). 

FIG. 5 shows power spectrum charts for the IKHz clock 
1 0 (symmetrical/asymmetrical). 

FIG. 6 shows a time domain analysis of a 24 KHz clock along with the IKHz 
clock with two different duty cycles. 



15 



5 




DESCRIPTION 



Fig. 1 shows an exemplary square wave g(t) with period T and pulse width x. 
The square wave can be described mathematically as follows: 

git) = A, -r/2<r<r/2 

= 0, For the remainder of the Period T. 

g(t) can be expanded using the Fourier transform: 



g{t) = Y.^n exp(y 2;ot/ / T) ^ where C,=\/T \g(t) exp(- J27mt I T)dt . 



As an example, for x = 111, (50-50 duty cycle), |C3|the magnitude of the third 
harmonic of the signal can be calculated as: IC3I = {AI37t\SIN{37t 12) = ^/(3;r) and for 
|C3| = (^/3;r).S/A^(3;rr/r), 
where \SIN{)\ < 1 . 

Thus, for any value of r T / 2 , the magnitude of the third harmonic is less than 
its value for a symmetric clock. 

Using r = r / 3 , C3 = l{3n).SIN{n) = 0 and the third harmonic can be 

minimized. 

As discussed next, the effect of third harmonic of IMHz clock on the output of 
the IF mixer at 3 MHz is significantly reduced in one exemplary embodiment of the 
invention. 
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The integral for C„ can be expressed as follows: 



C„ = {Alnn).SIN{nnrlT\n = 0,±1,±2,.... 




Figure 2 shows an exemplary clock generator. The system of Fig. 2 uses a 
relatively high frequency (in this example 24 kHz) clock/oscillator to generate an 
asymmetric low frequency clock (in this example a 1 KHz clock with 33/67 percent duty 
cycle). Figures 4-5 show the spectrum for both symmetric clock (50/50 percent duty 
5 cycle), and asymmetrical clock (33/67 percent duty cycle). 

In the example of Figures4-5, the clock generator is arbitrarily set for the 33/67 
percent duty cycle. However, any other duty cycle percentage can be used. As an 
example for generating the 33/67 percent duty cycle IkHz clock as in Figure 2, counter 1 
counts from (z - 1) to 0, where i = 24 for the embodiment of Figure 2. Counter 1 is a 
1 0 modular counter with modulo i and counts on the rising edge of the 24 KHz 
clock/oscillator. 

During the system initialization (reset), control logic resets the counter! to i. As 
long as 0 < counter! < {j - 1) where 7=8 control logic keeps the output signal at logic 
p high, otherwise it will keep the output signal at logic low. This process is repeated and 

n 

41 1 5 with appropriate parameters i& j\ different clock rates with the desired duty cycle can be 

Lit 

generated. Exemplary counter implementation in VERILOG is shown below. 
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-)t + + * + * + *+ ** + *** + + ********-(r***** + * DESCR J PTION ********************■***■***■***■**** + ****-* 
This module is a down counter that generates a clock with specific clock rate and 
duty cycle using the input clock and parameters 

Inputs : 

elk : high speed input clock 

reset : input reset signal 

vail : 5 bit input, number of elk cycles that output clock will be high 

val2 : 5 bit input, number of elk cycles that output clock will be low 

: vail & val2 will generate the desired duty cycle and clock rate 

Outputs : 

clk_out : output clock at the desired clock rate and duty cycle 



^timescale Ins/100 ps 

module downcntr (clk_out, elk, reset, vail, val2); 
//{ 

output clk_out; 

input elk, reset, vail, val2; 
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// 

wire [4:0] vail, val2; 
wire clk_out; 
// local register 
reg [4:0] count 1; 

// 

// generate 64 KHz from 4 MHz clock 
always @ (posedge elk or posedge reset) 
begin // { 

if (reset) 
else if {countl ==0) 
else 
end//} 



countl <= val2-l; 
countl <= val2-l; 
countl <= countl -1; 



assign clk_out = (countl <=(vall-l}); 
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//} end of the module 
endmodule 
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+ + * + + + * + 
This module 

rate and duty cycle using the input clock and parameters. 



+ + ** + + •*■*■*■ + * + ■*-■*•■*-**** DESCRI PTION + + + + * + + + + + + + * 

a testbench to test the down counter that generates a clock with specific clock 



Modules instantiated: 



downcntr 
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**-)ir* + -*- + *** + * + + + * + + * + **** + -**** + * Code 
"timescale Ins/100 ps 

module tdowncntr; 

//{ begin the module 
parameter- CLOCK = 41.6667; 
// parameter CLOCK = 250; 
reg elk, rst; 
wire clk_o; 

reg [4:0] vail, val2; 
downcntr clk_gen( 

.clk_out {cik_o), // output, clock 



// This is for 24 MHz clock 
// This is for 4 Mhz clock 



-elk (elk), 

.reset (rst), 

.vail (vail), 

.val2 (val2) 
) ; 



// input, 

// input 

// input 

// input 



high speed clock 



initial // Clock generator 
begin 
elk = 0; 

#80 forever « (CLOCK/2) elk 
end 



!clk; 



// These two parameters are set for generating iMHz clock from a 24 MHz clock with 
// duty cylce (1/3)/ (2/3) (1/3 microsecond clock will be high, and 2/3 microsecond 
// clock will be low 
initial //set the parameters 
begin 



vail 
val2 
end 

// 

initial 

begin 
rst 
#450 
#400 
#50000 

end 



5 'dOS; 
5'd24; 



rst 
rst 



// Test stimulus 



$stop 
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initial 

$monitor ($stime , , rst,, elk,,, elk o) ; 



//} end of module 
endmodule 
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Figure 3 shows an exemplary process that minimizes or eliminates nth-order 
harmonic, particularly nth-order harmonic associated with a square wave clock signal 
having a predetermined frequency and a duty cycle. The process includes changing the 
duty cycle of the clock to eliminate or suppress the nth-order harmonic of that clock (step 
12). Next, a low-interference clock having the changed duty cycle while keeping the 
predetermined frequency is generated (step 14). The low-interference clock can be an 
asymmetrical clock signal. Since the square wave clock has rising and falling edges, the 
changing of the duty cycle changes the position of the falling edge of the square wave 
clock respect to the position of the rising edge of the clock. 

Next, a simulation of an exemplary system for removing the third harmonic of the 
1 MHz clock on a digital IC is detailed. The system can be applied for suppressing any 
arbitrary harmonic by choosing the appropriate parameters. Code for performing the 
simulation in Matlab is shown in the Appendix and pictures of the signal spectrums at 1 , 
2, 3 KHz are shown in Figures 4-5. Figures 4 and 5 show the spectrum for both cases for 
T = T/2, and T/3. In Figures 4-5, the magnitude of the 3 KHz signal is the magnitude of 
third harmonic signal. The frequency is scaled from 1 MHz to 1 KHz to reduce the 
sampling rate. FIG. 6. shows a time domain analysis of the 24 KHz clock along with the 
1 KHz clock with two different duty cycles. 

Viewing Figures 4-6 in combination, changing the duty cycle of a square wave 
signal will eliminate or suppress different harmonics of that signal on a digital IC, 
Certain considerations in designing the digital IC and using this method to eliminate or 
suppress the harmonics for any clock signal on the chip include: 



1) Changing the clock duty cycle will change the position of the falling edge of the clock 
respect to the position of the rising edge of the clock. Thus, if both edges of the clock are 
used, the change in positions of the edges needs to be considered in the design. 

2) Eliminating one harmonic will change the magnitude of the other harmonic. In the 
example, from the spectrum of the signal, a symmetric clock does not have any second 
harmonic, but the modified clock with no third harmonic has a significant second 
harmonic. 

Although an illustrative embodiment of the present invention, and various 
modifications thereof, have been described in detail herein with reference to the 
accompanying drawings, it is to be understood that the invention is not limited to this 
precise embodiment and the described modifications, and that various changes and 
further modifications may be effected therein by one skilled in the art without departing 
from the scope or spirit of the invention as defined in the appended claims. 
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APPENDIX 



%% * + + + + + + + + * + + 4 INCLUDE FILE INFO * + + + + + + * + * + * 

%% 

%% Include File Name : harmonic_analysis .m 
%% Original Author : Masoud Azmoodeh 
%% Date of Origin : 09/04/2001 
%% 

%% COPYRIGHT 2001 - All Rights Reserved - Airify Communication, Irvine Ca 

%% 

disp{' + + + + * + + + DESCRIPTION ***************************************** ^ \ . 

disp ( ' ' J . 

dispC This is a matlab routine to analyze the effect of the third harmonics of 1 Mhz clock •); 
dispC on 3 MHz IF frequency. By changing the tau, the amount of the third harmonic will 
disp(" change. For theoretical details, please refer to third_harmcnicl.doc and to the Fourier'); 
disp(' transform of a periodical signal at any communication book, '); 
disp(* In this simulation, a 1 KHz signal is used instead of IMhz to reduce the sampling rate.'); 
disp ( ' < ) . 

disp ( ' < J . 

disp{' general shape of the square wave , •); 

disp ( ' - ) . 

disp ( ' I tau • ) ; 

disp ( ' — I — ' ) . 

dispC II II 11 
dispC I I ) I 1 j 

disp { ' 1 t J . 

disp ( ' I < > I ' ) ; 

disp ( ' IT ' } ; 

disp ( ' i ' ) . 

disp { ' I ' ) ; 

disp ( ' ' ) . 

dispC Please zoom on the pictures and verify the magnitude of the signal at 1, 2, 3 KHZ range'); 

disp { ' • ) ; 

disp(' +*■ + + ** + *■*■ + **■*■***■*■******■** + ** + *★ + *** Code ***********************************************) . 
%% 

%% Lets first generate a symetric square wave with f = 1000 hz clock, sampling f requency=96000 
%% 

clear; 

fs=96000; 

f=1000; 

T=fs/f; 

%% 

%%xl-square (2*pi*f/fs* [0:4999] ) ; %%This one needs signal processing toolbox that we do not have now 
tau=round( (48/96) *T); %% Using tau equal to 1/2 * period 

xll= [ones (1, tau) , zeros (1, T-tau) ] ; 

x22 = [ xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll xll ... 

xll xll xll xll xll xll xll xll xlll; 
xl = [ x22 x22 x22 ] ; 

f ftxl^f ft { (xl-mean (xl) ) , fs) ; 

figured); hold off; subplot { 2 , 1 , 1 ) , plot (20*logl0 ( le- 10+abs ( f f txl ( 1 : f s/2 ) ) )); zoom on; grid; 
title ( ' Spectrum of symmetric square wave, tau = T/2'); xlabel ( ' Hz ' ) ; 
ylabel ( '201og { I f ft ( ) I ) ' ) ; 

tau=round( (32/96) *T); %% Using tau equal to 1/3 * period, will totally get ride of the 3rd 

harmonic 

X 11= [ones ( 1, tau) , zeros ( 1 , T-tau) ] ; 

x22 = [ xll xll xll xll Xll xll xll xll Xll xll xll xll xll xll xll xll xll xll xll xll Xll ... 

xll xll xll xll xll xll xll xll xll]; 
x2 = [ x22 x22 x22 ) ; 
f ftx2=f ft ( {x2-mean (x2) ) , fs) ; 

subplot {2, 1, 2) , plot (20*logl0 ( le-lO+abs ( f f tx2 ( 1 : f s/2 ) ) )); zoom on; grid; 
title (' Spectrum of asymmetric square wave, with tau=T/3 '); xlabel (' Hz ') ; 
ylabel ( •201og ( I fft () I ) ' ) ; 
%% 

%% Lets try to generate the 1 Mhz clock from 48 Mhz input clock/oscillator 
%% First lets generate the 48 Khz clock 

tmpO =[1100 1100 1100 1100 110 0]; 

tmpl = [tmpO tmpO tmpO tmpO tmpC tmpO tmpC tmpO tmpO tmpO) ; 

x24 = [tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl tmpl]; 

figure(3); subplot (3, 1 , 1 ) ; hold off; 
subplot (3, 1, 1) ; hold off; 

plot (x24 (1:1.25*96) ,'') ; grid on;zoom on;hold on; plot (x24 ( 1 : 1 . 25*96) k .') ; 
title (' The 24 KHz clock/oscillator samples at 96 Ksps along with counterl data'); 
t2=0.1 

text ( 1, t2, • 10 ' ) ; 
%% 

tt=5; 

text (tt, t2, ' 9' ) ; text ( tt + 4 , t2 , ' 8 ' ) ; text ( tt + 2* 4 , t2 , ' 7 ' ) ; text ( tt + 3* 4 , t2 , ' 6 ' ) ; 
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text (tt+8*4, t2, • 1 ' ) ; 



text (tt+9*4, t2, ' 0' 



text {tt+4*4, t2, '5' } ; text (tt+5*4, t2, M ' ) ; text {tt+6*4 , t2, ' 3 ' ) 
%% 

text (tt+7*4, t2, '2' ) ; 
tt=tt-l; 

text (tt + 10*4, t2, '23' ) 
text (tt+13*4, t2, '20' ) 
text (tt-H6*4, t2, '17* ) 
text {tt+19*4, t2, '14' ) 
text {tt+22*4, t2, '11' ) 
tt=tt+l; text(tt+24 



text (tt + 25*4, t2, '8' ) ; 
text {tt+28*4 , t2, '5' ) ; 
%% text {tt + 31*4, t2, '2' ) 
%% text (tt + 34*4 , t2, ' 23' 



text (tt + ll*4, t2, '22' ) 
text (tt + 14*4, t2, '19' ) 
text (tt+17*4,t2,'16* } 
text {tt+20*4, t2, '13' ) 
text (tt+23*4, t2, *10' ) 
, t2, '9*) ; 
text (tt + 26*4 , t2, ' 7 ' ) ; 
%% text (tt+29*4 , t2, ' 4 ' 



text {tt+12*4, t2, 
text (tt + 15*4, t2, 
text (tt+18*4, 
text (tt+21*4, 



, t2, 
,t2, 



text (tt + 32*4, t2, • 1' } ; 



text ( tt+27*4 , 
text (tt+30 
text (tt+33 



•6'},- 
t2, '3' ) ; 
t2, '0' ) ; 



%% 

subplot (3,.l, 3) ; hold off; 

tmpl=[ zeros(l,12), xl ( 1 : 96* 1 . 25-12 )] ; 

plot ( tmpl , ' ' ) ; hold; plot (tmpl, ' k. ' ) ; grid on; zoom on; 

title {.' The 50/50 percent duty cycle 1 KHz clock generated using 24 KHz oscillator/clock sampled at 96 

Kilo samples per second'); 

%% 

subplot {3, 1, 2) ; hold off; 

tinp2=[ 2eros(l,12}, x2 ( 1 : 96*1 . 25-12 }] ; 

plot ( tmp2 , • • ) ; hold on; grid on; zoom on; plot ( tmp2 , ' k . ' ) ; 

title {' The 33/67 percent duty cycle 1 KHz clock generated using 24 KHz oscillator/clock sampled at 96 

Kilo samples per second'); 

%% 
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